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(54) Electronic television program guide system and method 



(57) An electronic programming guide (70) operates 
on a computing platform (12) associated with a televi- 
sion (40). The platform (12) accesses a program listing 
database (48) containing program listing information (6) 
for a plurality ol television programs. The electronic pro- 
gramming guido (70) includes a profile database (80) 
that stores a viewer profile (84) and a suggest modulB 
(76) 1hat is coupled to the profile database (B0). The sug- 
gest module (76) accesses the viewer profile (B4) end 



the program listing information (6) and, in response, 
generates a preferred schedule (100) according to the 
viewer profile (84) and the program listing information 
(6). The preferred schedule (100) indicates the desira- 
bility of a particular program relative to other programs. 
The electronic programming guide (70) may also be 
used to Instruct a recorder (20) to record a television 
program In accordance with the program listing informa- 
tion (6) and viewer input information that does not spec- 
ify broadcast inlormalion concerning the program. 
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Description 

TECHNICAL FIELD OF THE INVENTION 

This invention relates in general to the field of tele- 
vision, and more particularly to an electronic program- 
ming system and method. 

BACKGROUND OF THE INVENTION 

Many television viewers wish to select, schedule, 
and record their television viewing opportunities to en- 
hance the television viewing experience. To do this, 
many select programs lor viewing after censuring a pa- 
per or electronic programming schedule to determine 
the programs available during particular time slots. Oth- 
ers change from channel lo channel in an attempt to lo- 
cale desirable programming, with varying degrees of 
success. 

As the number of television channels and television 
programs continues to increase, allowing viewers to 
more intelligently select, schedule, and record their 
viewing opportunities becomes increasingly important. 
An existing technique lor electronically accessing pro- 
gram scheduling information includes periodically 
downloading scheduling information and, in response lo 
requests from the viewer, providing this scheduling in- 
lormalton in raw form to the viewer. Even though such 
techniques may allow the viewer to display only pro- 
grams of a particular genre, the viewer must still either 
inspect listing information for programs individually to 
make informed channel and program choices or waste 
time 'channel surfing" through the programs thai are 
displayed. Because such techniques do not provide any 
direct channel tuning assistance, they are inadequate 
to meet the needs of many viewers. Moreover, prior 
techniques do not allow the viewer to restrict viewing ol 
particular programs or programs having particular char- 
acteristics lo certain viewers within the household, such 
as children, without first inspecting a program schedule 
to determine broadcast information foe the programs, 
such as air dales, start times, stop times, and channels. 

Furthermore, electronic program guide (EPG) dis- 
plays that consider viewer preference ^formation are 
subject to error, require the viewer to have soma under- 
standing of the particular scoring algorithm used, are 
confusing to viewers thai change from one EPG to an- 
other EPG, and do not allow lor identification of pre- 
ferred program clustering, which severely Emit the ability 
to accurately and efficiently plan quality viewing lime. In 
addition, prior techniques for recording programs re- 
quire viewers 1o input detailed broadcast information, 
such as air dates, start limes, stop times, and channels, 
or special program codes to record particularprograms, 
are subject to error if a program to be recorded is longer 
lhan usual or expected, is preempted, is rescheduled, 
is changed from one channel to another channel, or oth- 
erwise varies from the expectations at the viewer in any 



manner, and do not allow viewers lo record particular 
programs or types of programs that the viewers are most 
likely to enjoy based on viewer preferences or other in- 
put information that does not specify broadcast inlorma- 
s u'on for the programs. These and other inadequacies 
make prior techniques unsuitable for many viewers. 

SUMMARY OF THE INVENTION 

io The present invention addresses the disadvantag- 
es and problems previously associated with television 
viewing and recording. 

According lo one embodiment of the present inven- 
tion, an electronic programming guide operates on a 
computing platform that is associated with a television 
Tho ptatlorm accesses a program listing database con- 
taining program fisting information for a plurality of tele- 
vision programs. The electronic programming guide in- 
cludes a profile database that stores a viewer protile and 

so a suggest module that is coupled to the profile database. 
The suggest module accesses the viewer profile and the 
program listing information and, in response, generates 
a preferred schedule according to Ihe viewer profile and 
the program listing information. The preferred schedule 

25 indicates the desirability of a particular program relative 
to other programs. 

In another embodiment of the present invention, a 
method (or recording a television program is performed 
on a computing platform associated with a television 

30 and a recorder. Viewer input information is received that 
does not specify broadcast information concerning the 
program. Program listing information lor a plurality of 
programs is stored in a program listing database cou- 
pled to the platform. The program listing information is 

as accessed and compared to the input information to gen- 
erate recording information for the program accord fig 
to ihe comparison. The recording information for the 
program is communicated to the recorder to instruct the 
recorder lo record the program. 

*o The electronic programming system and method of 
Ihe present invention provides a number of important 
technical advantages. The present invention generates 
profiles for one or more viewers that are used to score 
att available programming to determine which programs 

« are most likely lo appeal to the viewers. The resulting 
information is then provided in a simple and understand- 
able format that allows the viewers to more intelligently 
select, schedule, and record viewing opportunities with- 
out inspecting broadcast information for particular pro- 
se grams. The program-based nature of tho present inven- 
tion allows Ihe viewer to tuna lo more desirable pro- 
gramming at any time during a viewing session and to 
record particular types of programs at any time before, 
during, or after a viewing session according lo the view- 

SS er preference information used to establish the viewer 
prolilo. Furthermore, viewers need nol block entire 
channels to restrict viewing of undesirable programs to 
certain viewers within the household, such as children. 
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schedule, and record viewing opportunities according to 
viewer profiles and information received-using link 14. 
The structure of platlorm 12 is discussed more fully be- 
low with reference to FIGURE 2. Although JAVA Is dis- 
s cussed, any other ptattorm irtdependeni programming 
language or other suitable programming language may 
be used without departing (rom the intended scope ol 
the present invention. 

Link 1 4 may be any dedicated or switched connec- 
i0 Son to a public swiich telephone network (PSTN), an in- 
tegrated services digital network (ISDN), a coaxial cable 
network, a satellite or microwave link, or any other wiro- 
tess or wireline communicalions link suitable to couple 
platlorm 12 to the Internet. Although the Internet isdis- 
is cussed, the present invention contemplates any global, 
regional, local.. or other suitable computer network cou- 
pled to platlorm 12. Database server 46 coupled to the 
Internet accesses program listing database 48, which 
guide according to the present invention; contains television programming formation that is pe- 

RGURE4illust r atesanexempU,r yP rBlerence l em- » radically updated accord.ng to the operat.on of an or 

ganization associated in some "^"^ At 



In addition, the present invention allows 
record particular programs without providing or even 
having access to broadcast information such as air 
dates, start times, stop times, and channels. 

BRIEF DESCRIPTION OF THE DRAWINGS 

For a more complete understanding of the present 
invention and lor further features and advantages there- 
of, reference is now made to the following description 
taken in conjunction with the accompanying drawings, 
in which: 

FIGURE 1 illustrates a JAVA-enabled television 
system according 1o thB present invention; 
FIGURE 2 illustrates a JAVA-based operating hier- 
archy according to the present invention; 
FIGURE 3 illustrates art electronic programming 



plate according to the present invention; and 
FIGURE S illustrates an exemplary preferred 
schedule according to the present invention; 
FIGURE 6 is a flow chart illustrating an exemplary 
mothod for selecting a program lor viewing accord- 
ing to the present invention; and 
FIGURE 7 is a flow chart illustrating an exemplary 
method for recording a television program accord- 
ing to the present invention. 

DETAILED DESCRIPTION OF THE INVENTION 

FIGURE 1 illustrates a JAVA-enabled television 
system 2 that includes a JAVA-enabled television re- 
ceiver 10 that is associated with a television or other 
suitable display dovico 40/ and a recorder 20. such as a 
video cassette recorder (VCR), video disk recorder, or 
other recording device suitable to record video and au- 
dio television signals. Receiver 10 includes a JAVA- 
based platform 12 that operates on one or more proc- 
essors 8. such as a digital signal processor (DSP) chip 
manufactured by TEXAS INSTRUMENTS INCORPO- 
RATED, an advanced reduced instruction set computer 
(RISC) machine (ARM), or any other suitable process- 
ing ptattorm. Platform 12 is coupled to the Internet and 
associated sources of Internet information using a bidi- 
rectional link 14. In general, platform 12 provides a col- 
loction of application programming interfaces (APIs) 
that allow platlorm 12 to synchronize and integrate tel- 
evision signals and Internal information lor display on 
television 40, to support JAVA applets or applications 
that provide interactive television programming, and io 
support JAVA applets or applications that provide a wide 
variety of functionalities related to television program- 
ming. In ono embodiment, as discussed more fully bo- 
low with reference to FIGURE 3. platlorm 12 supports 
an electronic programming guide JAVA applet or appli- 
cation that allows viewers to more intelligently select, 



with server 46 

and database 48. In one embodiment, database 48 con- 
tains program listing information 6 for each program 
available for viewing within the next day, week, month. 
25 or other specified period from television signal source- 
26, which may be any suitable cable television system 
(CATV), direel broadcast satellite system (DBS), regular 
satellite broadcast system, conventional television 
broadcast system, or other suitable system for providing 
30 television signals 1o receiver 10, 

For each program for which database 43 has listing 
information, program listing information 6 may include, 
without limitation: program dates; start times; stop 
times; a program length; program channels; program 
3$ genres; a list of actors for the program; a list of sports 
teams to which the program may relate in some manner; 
keywords associated with the program that describe Iho 
program in some manner; a synopsis of the program; 
whether the program is a rerun, premiere, finale, mini- 
40 series, movie, special, or any other type of program; 
whether the program b a closed-caption ed program; 
whether the program is in stereo; a Motion Picture As- 
sociation of America (MPAA) raling or other raling for 
the program; content information concerning nudity, 
as adult situations, adult language, violence, or other any 
other type of content; and any other appropriate pro- 
gram listing information 6. An electronic programming 
guide (EPG) JAVA applet or application running on plat- 
lorm 1 2 periodically accesses database 48 using link 1 4 
so and server 46 to receive program listing information 6 
thai allows the EPG applet or application to provide tel- 
evision-related functionalities to viewers associated 
with receiver 10 and lelevision 40, as discussed-more 
fully below with reference to FIGURE 3. Although data- 
« base 4B is discussed, the present Invention contem- 
plates a suitable database integral lo receiver 10 and 
periodically updated by one or more service providers 
external lo receiver 10 using link 14. for example, daily, 
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weekly, of on any other periodic basis, lo include pro- 
gram listing information 6 accessible lo platform 12. 

Receiver 10 includes one or more tuner/decoders 
24 that couple to platform 12 using tuner/decoder con- 
trol line 22 and receive television signals from source 
26. either directly or through recorder 20. Recorder con- 
trol line 1 6 couples platform 1 2 to recorder controller 1 8 
lhat controls recorder 20 according to the operation ol 
platform 12. One or more audio/video overlays 32 are 
coupled to platform 1 2 and coordinate the integration ol 
television signals and Internet information in accord- 
ance with the operation of platform 12. A vertical blank- 
ing interval (V8I) decoder 23 coupled to tuner/decoder 
24 receives decoded television signals from tuner/de- 
coder 24. separates information Irom the VBI I rem the 
decoded television signals, lor example, Intercast, 
ctosed-captioning. Teletext, or arty other VBI informa- 
tion, and communicates the separated VBt information 
to platform 12. Tuner/decoder 24 also communicates 
the decoded television signals to audio/video overlays 
32 using television line 34. Audio/video overlays 32 
communicate outputs to video output 36 and audio out- 
put 38. 

In one embodiment, video output 36 is a super video 
(S-video) output with RCA jack cable support or any oth- 
er suitable video output. Audio output 38 may support 
any suitable combination of mono, stereo, surround, or 
other audio information. Video output 36 and audio out- 
put 35 are coupled lo television 40, although the present 
invention contemplates video output 36 and audio out- 
put 33 integral to television 40 in accordance with the 
design of receiver 10 and system 2, Input device 42 in- 
cludes a remote control touch screen, mouse, keypad, 
or other suitable pointer to communicate infrared, elec- 
tronic, or other input signals lo input receiver 44 of re- 
ceiver 10. Components of receiver 10 may be at one or 
more locations integral to or separate from television 40, 
such as a set top box, a network computer or other 
processing device, or any other component coupled to 
television 40. 

In operation ol system 2, tunerAdecoder 24 receives 
a television signal from source 26, either directly or us- 
ing recorder 20, and decodes the television signal as 
necessary or appropriate. In one embodiment, multiple 
tuner/decoders 24 are used to provide images suitable 
for a television picture display. Before, during, or after 
tuner/decoder 24 receives iho television signal from 
source 26, a viewer associated with television 40 selects 
a particular channel for viewing, using input device 42 
or in any other suitable manner. Tuner/decoder 24 com- 
municates a decoded television signal corresponding to 
the selected channel to audio/video overlays 32 and VBI 
decoder 23, which in turn communicates the separated 
VBI information to platform 1 2. More or less sinuftano- 
ousry. ptallorm 12 receives Internet information using 
link 1 4 for integration with the decoded television signal 
according to a JAVA applet or application operating on 
platform 12. Also operating on platform 12 is an elec- 



tronic programming guide JAVA applet or application 
thai provides various functionalities that- allow viewers 
to more intelligently select schedule, and record view- 
ing opportunities according to viewer profiles and infor- 

s mat km retrieved from database 43, as discussed more 
fully below with reference to FIGURE 3. 

Ptatlorm 12 contains channel mapping information 
that associates the television signal for each channel 
with one or more uniform resource locators (URLs) used 

io lor accessing Internet information corresponding lo the 
channel. For example, it the viewer selects the CABLE 
NEWS NETWORK (CNN) for viewing, platform 12 might 
use the channel mapping information to associate the 
channel carrying CNN with a URL for an Internet web 

« site associated with CNN. such as htlpyAvww.cnn.com. 
Using the URL and other appropriate information, plat- 
form 12 retrieves the associated web page using Inter- 
net link 14. AudioArideo overlays 32 integrate the web 
page, any appropriate VBI information received from 

so VBI decoder 22. and the television signal Tor the select- 
ed channel received from tuner/decoder 24 accordhg 
to the JAVA applet or application operating on platform 
12 that controls the integration of this information. Au- 
dio/Video overlays 32 then communicate the integrated 

2S information to television 40 using video output 36 and 
audio output 38 for viewing. 

Typical integration of television signals and Internet 
information might result visually as the regular television 
broadcast in a first display area on television 40 and the 

30 Internet information in a second display area on televv 
sion 40. In one embodiment, platform 1 2 allows the first 
and second display areas to be moved, sized, merged, 
blended, overtayed, or manipulated according to the 
corresponding JAVA applet or application to provide 

35 more sophisticated collective displays than were possi- 
ble using prior systems. The present invention contem- 
plates communicating a URL or other Internet informa- 
tion corresponding to a channel from source 26 using 
the VBI associated with the particular television signal 

*o for the channel. VBI decoder 24 would decode and com- 
municate this information to platform 1 2, which would 
then access the appropriate URL using Internet link 14 
to retrieve Internet information lor integration with the 
television signal. Other suitable arrangements for ob- 

4S taining a URL or other inlormation necessary to allow 
platform 12 to integrate television signals and Internet 
inlormation are contemplated, without departing tram 
the intended scope ol the present invention. 

Since the web page that platform 1 2 accesses us'ng 

bo the URL and integrates with the television signals lor the 
corresponding channel may provide information relathg 
to the subject matter of the television program, the view- 
or is able to interact with one medium to conveniently 
access a great deal of information concerning a topic. 

$s In addition, the Internal information thai platform 1 2 syn- 
chronizes and integrates with the corresponding televi- 
sion signals may include information regarding other re- 
lated web sites, en associated chat room in which the 
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viewer might discuss the program wilh olher viewers 
during tha program, or any other Internet inlormation. 
During a commercial break in the program, inlormation 
regarding the advertised product might be retrieved 
(rom a web site associated with the product and syn- 
chronously and integrally displayed along whh the com- 
mercial. In addition, as discussed more fully below with 
reference to FIGURE 3, platform 1 2 supports a JAVA- 
based electronic programming guide (EPG) that allows 
one or more viewers lo more intelligently select, sched- 
ule, or record viewing opportunities according to viewer 
profiles and program listing information 6 to enhance the 
television viewing experience. 

FIGURE 2 illustrates an exemplary JAVA-based op- 
erating hierarchy 50 lor system 2 and platform 1 2 that 
includes a number of levels, each containing a collection 
of hardware, software, or both hardware and software 
suitable to perform the functions of system 2 and plat- 
form 12. First level 51 includes conventional television- 
related hardware 52, such as recorder controller 1 B, tun- 
er/docodor 24, VBI decoder 28. video output 36, audio 
output 38, input receiver 44. and any other suitable hard- 
ware and software associated with receiver 1 0, recorder 
20, and television 40. Second level 53 of hierarchy 50 
includes one or more interactive television protocols 54, 
lor example. Digital Audio/Video Interactive Decoder 
(DAVID) and Interactive Communications Applications 
Protocol {I CAP). Third level 55 of hierarchy 50 includes 
a basic JAVA operating system 56 with JAVA RUN- 
TIME, which implements the JAVA VIRTUAL MACHINE 
to provide various taw level JAVA capabilities such as 
windowing, networking, and file management, together 
with appropriate JAVA extensions that augment basic 
JAVA APIs and associated classes according to the 
functionalities associated with platform 12. One such 
functionality, as discussed more fully below, is support- 
ing an electronic programming guide JAVA applet cr ap- 
plication that allows viewers to select, schedule, and 
record viewing opportunities according to viewer pro- 
files and program listing information 6 retrieved trom da- 
tabase 48. 

■ Fourth level 57 includes a JAVA toolkit 58 having a 
collection of APIs 60 that cooperate with JAVA operating 
system 56 to allow JAVA applets 64 and applications 62 
in fifth level 59 lo perform functionalities associated with 
JAVA applets 64 and applications 62. In one embodi- 
ment, APIs 60 of toolkit 53 allow platform 1 2 to support 
JAVA applets 64 downloaded from the Internet over link 
1 4, JAVA applications 62 installed locally on receiver i 0 
or any processing platform associated wilh receiver 10, 
or any other appropriate JAVA program that uses the 
television-related functionalities of APIs 60. Since toolkit 
58 and APIs 60 aro designed to support any appropriate 
JAVA applet 64 or application 62, the viewer is not lim- 
ited to applets 64 or applications 62 from particular con- 
tent developers, but may download any JAVA applet 64 
or install any JAVA application 62 that provides the de- 
sired tunci ionality without concern regarding compattoil- 



ity with platform 12. Furthermore, toolkit 58 allows de- 
velopers lo write applets 64 and applications 62 that pre- 
sume an ability on the part ol platform 12 to integrate 
television signals and Internet information, to provide in- 
$ teractive television programming, to allow viewers to 
more intelligently select, schedule, or record viewing op- 
portunities according to viewer profiles and program list- 
ing inlormation 6, and to support any other suitable tel- 
evision-related functionality. 
'0 In one embodiment, each API 60 includes a collec- 
tion of JAVA (unctions and supporting classes that are 
related to a particular task or combination of associated 
tasks and extend the basic JAVA APIs discussed above. 
For example, a control API 60 contains classes that sup- 
's port (unctions to integrate television signals into JAVA 
applets 64 and applications 62 as discussed above. 
Control API 60 also includes classes that control video 
and audio properties associated wilh television 40. for 
example, and not by way ol limitation: controlling televi- 
se sion overlay operations, such as color overlay koy ing to 
ovorfay JAVA animations: setting channel numbers; set- 
ting the position, width, and height of the television sig- 
nal video component within an integrated display; turn- 
ing the video or audio on or ott; freezing or unfreezing 
25 the video; setting video brightness, contrast, color, or 
tint; setting audio volume, balance, bass, and treble: and 
any olher suitable property related to the inlormation 
presented on television 40. 

In addition, control API 60 may include classes that 
oo define mapping between channel numbers, identifiers, 
and associated URLs; associate electronic program 
guides with channels; represent data streams transmit- 
ted in the VBI associated with channels; update the in- 
tegrated displays presented on television 40 according 
as to changes in content on the associated channels; and 
perform any other activity associated with the incorpo- 
ration of television signals into the JAVA environment of 
platform 12. For example, with respect to updating inte- 
grated displays, if a program switches to a commercial 
to break, control API 60 may cause a web page or other 
Internet information associated wilh the advertised 
product to be displayed on television 40 in synchroniza- 
tion with the displayed commercial to provide additional 
product information or an opportunity to order or com- 
4$ ment on the product. URLs and other appropriate infor- 
mation communicated In the VBJ may cooperate to allow 
platform 12 to provide mapping functionality. Control 
API 60 also includes classes for controlling various op- 
erations of recorder 20, for example, starting, stopping, 
w playing, recording, pausing, fast-forwarding, and re- 
winding. The present invention contemplates any class- 
es suitable to allow control API 60 and platform 12 lo 
support television -related JAVA applets 64 and applica- 
tions 62. regardless of the content developer or partic- 
55 ular operation. 

Toolkit 58 may include a datacast API 60 that in- 
cludes classes to support access lo data communicated 
along with the television signals from source 26. such 
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as Intercast, closed -captioning. Teletext, and other V81 
information. A showlel API 60 ol toolkit 53 includes 
classes that support interactive television programming, 
such as for shopping, advertising, pdhng, distance 
teaming, participation in game shows, banking, and any 
other interactive programming. As discussed above, 
since toolkit 56 and associated APIs 60 of platform 12 
support JAVA applets 64 and applications 62 having any 
appropriate operation, the number ol interactive pro- 
gramming opportunities that plaltorm 1 2 and system 2 
provide is virtually limitless. 

Toolkit 58 also includes an electronic programming 
guide (EPG) API 60 that contahs classes tor querying 
(or. retrieving, and manipulating program listing informa- 
tion 6 contained in program listing database 48, con- 
structing and modifying viewer profiles according to 
viewer preferences, constructing electronic scheduling 
displays according to viewer profiles and selected pro- 
gram listing information 6. and providing other desirable 
functionalities that allow viewers to more intelligently se- 
lect, schedule, and record viewing opportunities. An 
EPG applet or application 70 thai operates using EPG 
API 60 and other APIs 60 of toolkit 53 in accordance 
with the present invention is discussed more fully below 
with reference to FIGURE 3 As shown in FIGURE 2. 
JAVA operating system 56 and toolkit 58 implement plai- 
lorm 1 2 Icy running JAVA applets 64 and applications 
62 in fifth level 59 of hierarchy SO. Although hierarchy 
50 is discussed with discrete levels that run on proces- 
sor 8 ol receiver to. the present invention contemplates 
one or more levels thai are integral to one another or 
levels that are distributed to run on separate compo- 
nents of receiver 10 or system 2. interactive television 
protocols 54, JAVA operating system 56, and toolkit 59 
with associated APIs 60 may be referred to collectively 
as platform 12. 

As an example of the operation of APIs 60, consider 
an EPG applet 70 that is downloaded from the Internet 
to run on platform 1 2. In one embodiment, as discussed 
below with reference to FIGURE 3, functionality associ- 
ated with EPG applet 70 includes recording a television 
program that is scheduled for broadcast on some un- 
specified date in the luture. After EPG applet 70 is down- 
loaded and begins to run. EPG applet 70 calls EPG API 
60 and other APIs 60 as appropriate to accomplish spe- 
cific tasks. To record a particular program, lor example, 
EPG applet 70 might call a routine associated with EPG 
API 60 that queries program listing database 48 to de- 
termine the air date, start time, stop time, and channel 
on which the particular program is scheduled tor broad- 
cast, passing a program name or other program identi- 
fier to EPG API 60. EPG API 60 might then periodically 
query database 48 until the date ol broadcast and the 
current date are identical. After determining that the pro- 
gram is scheduled lor broadcast on the current date. 
EPG API 60 might call a routine associated with control 
API 60 that sets recorder 20 to record, passing the start 
lime or other information appropriate for initiating re- 



cording ol the program. Similar operation might occur to 
stop the recording or perform any other suitable func- 
tionality that EPG API 60 and other APIs 60 ol toolkit 53 
support Since the calls from EPG applet 70 to APIs 50 

S and between APIs 60 are resolved at run time in the 
JAVA environment associated with platform 1 2. platform 
12 is able to support virtually any appropriate EPG ap- 
plet 70, which provides an important technical advan- 
tage. Although EPG applet 70 is discussed, the above 

w discussion would apply equally to a suitable EPG appli- 
cation 70. 

FIGURE 3 illustrates JAVA-based electronic pro- 
gram guide [EPG) 70, which may run on platform 12 and 
processor 8 as a JAVA applet 64 downloaded from the 

' s internet over link 1 4 or as a JAVA application 62 instaQed 
locally on receiver 10 or an associated processing plat- 
lorm. In one embodiment, EPG 70 includes a control 
module 72, a profile module 74, a suggest module 75. 
and a schedule module 73 that cooperate to provide var- 

20 ious E PG functionalities, as discussed below According 
to operation ol control module 72. profile module 74, 
suggest module 76. schedule module 78. and any other 
appropriate components. EPG 70 uses EPG API 60 lo 
access program listing information 6 in database 43 in 

2S cooperation with database server 46, as discussed 
above with reference to FIGURE 1. The present inven- 
tion contemplates storing program listing information 6 
locally at receiver 1 0 and periodically updating program 
listing inlormation 6 to replace or combine with access- 

30 ing database 48 using link 1 4. In general. E PG 70 allows 
a viewer to more htetEgently select, schedule, and 
record viewing opportunities according lo program list- 
ing information 6 and a viewer profile associated with 
the viewer. 

35 Control module 72 interfaces with the components 
of platform 12 and system 2 as necessary to retrieve 
program listing information 6. For example, it program 
listing information 6 for a particular program is desired, 
control module 72 might call a routine associated with 
*o EPG API 60 to retrieve the desired program listing in- 
formation 6 in database 48 corresponding to the pro- 
gram, passing suitable information concerning the pro- 
gram and the desired program listing information 6 to 
EPG API 60. After the appropriate program listing infor- 
ms ma; ion 6 is returned, control modulo 72 communicates 
program listing information 6 to other components of 
EPG 70. such as profile module 74 or suggest module 
76, according to the operation of these components. 
Control module 72 also coordinates communications 
*f between profile module 74, suggest module 76, and 
schedule module 78 as appropriate. In one embodi- 
ment, control module 72 prompts the viewer for and re- 
ceives a viewer identity in response to the viewer turning 
on television 40 or in some other manner accessing the 
ss resources of EPG 70. 

Profile module 74 receives preference inlormation 
from one or more viewers associated with receiver 10, 
such as multiple viewers within a family that owns JAVA- 
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enabled tolovision system 2. and constructs, builds, or 
otherwise generates corresponding viewer profiles 84 
(or storage in profile database 60. The present invention 
contemplates each viewer having a separate viewer 
profile 84. one or more viewers, such as children, having 
a combined viewer profile 34, of any other suitable ar- 
rangement with respect to viewer profiles 64. Further- 
more, one or more viewer profiles 84 may be addod. 
doloted. modified, inactivated, reactivated, or otherwise 
manipulated at any time according to operation o( EPG 
70. Profile database 80 may include onB or more data- 
bases, files, lists, or other arrangement ol information at 
one or more locations that are integral to or separate 
Irom receiver 10. 

In one embodiment, profila database 80 also con- 
tains ono or more preference templates 82 that profile 
module 74 may access and communicate to a viewer 
using control module 72 to receive preference informa- 
tion from the viewer. For example, EPG 70 may com- 
municate one or more preference templates 82 to a 
viewer in response 1o the viewer pointing to, clicking on. 
or otherwise selecting a profile set-up option that EPG 
70 displays on television 40 as part of a windowing menu 
associated with EPG 70. The viewer might then select 
a particular preference template 82 to begin construct- 
ing or modifying viewer profile 84 associated with the 
viewer The present invention contemplates viewers in- 
teracting with EPG 70 in any suitable manner to select 
preference templates B2. EPG 70 may also allow the 
viewer to use input device 42 to hyperlink between tem- 
plates 82 or viewer profiles 84 displayed on television 
40 according to the operation of EPG 70 and particular 
needs. 

Preference templates 82 stored in profile database 
00 may include, without limitation: a genre template 82 
that lists possfcle program genres, (or example, drama, 
horror, comedy, romance, or other program genre; an 
actor template 82 that lists actors that may appear in a 
program; a sports team template 82 that lists sports 
teams to which a program may relate in some manner, 
for example, if the program is an alhletic contest, a doc- 
umentary, or other sports-related programming; a key- 
word template 82 that lists keywords that may describe 
the program in some manner, for example, non-stop, 
heart-warming, exciting, romantic, or other suitable key- 
words; and any other suitable preference template 82 
suitable for constructing viewer profile 84 according to 
preference information associated with the correspond- 
ing viewer. Multiple preference templates 82 may in- 
clude the same or similar optionslhat result in the viewer 
providing the same or similar preference Information. 
For example, a viewer might select ■educational" as a 
prelerence using both genrB template 82 and keyword 
template 82. In one embodiment, options given the 
viewer in connection with templates 82 correspond to 
program listing information 6 that database 48 may con- 
tain currently or at some point in the future, depending 
on the particular programs for which database 48 con- 



tains program listing information 6 and other suitable 
[actors. ■ 

For each option presented to the viewer in connec- 
tion with preference templates 82, preference templates 
s B2 allow the viewer to provide ranking information that 
EPG 70 uses to generate viewer profile 84 and provide 
enhanced viewing opportunities according to viewer 
profile B4, as discussed more fully below Referring to 
FIGURE 4. genre prelerence template 82 includes op- 
10 tions 86 and corresponding rankings 88 in any suitable 
presentation format that is viewable on television 40. In 
one embodiment, the viewer provides a ranking 88 for 
each option 86 to indicate the desirability ot program- 
ming associated with option BS according to any suitable 
IS scale, standard, or other criteria. For example, for each 
option 86, template 82 might include any number of cir- 
cles, boxBS, or other locations on template 82 that each 
correspond to a qualitative assessment of the degree to 
which the viewer will likely enjoy programming associ- 
20 ated with option 66. 

To provide rankings 88 tor options 36. the viewer 
would simply point to, click on, or otherwise indicate the 
appropriate locations using input device 42 or in any oth- 
er suitable manner. Each location may also be associ- 
ss ated with a numerical value or weight that quantifies Ihe 
assessment ot the viewer for purposes of scoring pro- 
grams according to viewer profile 84, as discussed more 
fully below. For example, if ■comedy" option 66 is highly 
preferable to the viewer, the viewer might indicate the 
so last location to the right in FIGURE 4 to provido ranking 
88, which might then have a "10* weight. Similarly, if 
•drama* option 85 is mildly preferable to Ihe viewer, the 
viewer might indicate the next to last location to the right 
to provide ranking 68. which might then have a "3' 
3$ weight. An option 86 with respect to which the viewer is 
neutral might get ranking 88 with a "0" weight, an option 
86 mildly unpreferable to the viewer might receive rank- 
ing 8S with a "-3" weight, and an option 86 highly un- 
preferable to the viewer might receive ranking 88 with a 
40 *-i 0" weight. The present invention contemplates any 
evaluation or weighting technique suitable lo allow view- 
ers to provide rankings G8 tor some or all options 85 as- 
sociated with template 82. 

EPG 70 may allow the viewer lo hyperlink to dis- 
« plays that provide additional descriptions, examples, or 
other suitable information by selecting a particular op- 
tion 86 using input device 82. Genre template 62 may 
include an exit window 90 allowing the viewer to exit 
genre template 82 and return to a prelerence template 
so menu or any other appropriate menu after providing 
preference information in accordance with genre tem- 
plate 82. Although genro template 82 is discussed, the 
present discussion applies equally lo any other suitable 
preference templates 82, such as actor template 92, 
55 sports team template 82, or keyword template B2. Alter 
the viewer has provided prelerence inlormation to EPG 
70 using the appropriate templates 62. profile module 
74 stores the preference information tor the viewer in 
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profile database £0 as a new or modified viewer profile 
B4 (or tho viewer. EPG 70 may generate and store view- 
er profiles 34 lor each viewer associated with system 2, 
may combine one or more viewer profiles 34 in accord- 
ance with particular needs, or may generate viewer pro- 
files 64 in any other manner accordbg to preference in- 
formation that one or more viewers provide to EPG 70. 

Suggest module 76 accesses program listing infor- 
mation 6 j) database 43, direct (y or using control modulo 
72. and viewer profiles 84 in profile database SO to gen- 
erate a preferred programming schedule that allows 
viewers to more intelligently select programs that may 
be desirable for viewing or recording. FIGURE 5 illus- 
trates an exemplary preferred schedule 100 that corre- 
sponds to the available television programming be- 
tween 6:00p m. and 1 2:00p.m. on a particular date. Pre- 
ferred schedule 100 includes channel programming 
102. 104. 106, 108. 110. and 1 1 2 corfospcoding to first, 
second, third, fourth, fifth, and sixth channels, respec- 
tively, although the present invention contemplates any 
number of channels. Channel programming 102. 104, 
10G, 103, 110. and 112 are referred to generally aschan- 
nel programming 102 unless otherwise indicated. Each 
program for which preferred schedule 100 has channel 
programming 102 may fill some or atl of one or more 
time slots,! 14. which are each thirty minutes long in the 
example shown in FIGURE 5, yielding Ihe brick-like ap- 
pearance of preferred schedule 100. Button 118 on pre- 
ferred schedule 1 1 3 allows the viewer to hyperlink or es- 
tablish a connection to a preference template menu or 
a display of viewe r profile 84. Preferred schedule 1 00 is 
referred to as including channel programming 1 02, scor- 
ing indicators 116 and program scores used to general e 
scoring indicators 1 1 6. as discussed below, and any oth- 
er suitable information associated with preferred sched- 
ule 100, EPG 70 may temporarily or more or lass per- 
manently store preferred schedule 100 at any suitable 
location. 

Using viewer profile 84 and an appropriate scoring 
algorithm 77, suggest module 76 generates a color cod- 
ed, numerical, or other scoring Indicator 116 for each 
program for which channel programming 102 and pre- 
ferred schedule 100 contain programming information. 
Additional textual or other suitable information concern- 
ing the program might be associated with scoring hdi- 
cator 116. In general, scoring indicator 116 visually in- 
dicates lo the viewer a degree of desirability likely to be 
associated with a corresponding program, based on 
viewer profile 84 tor the viewer. For example, scoring 
indicator 1 16 may include color or shading that overlays 
textual information concerning the program, such as 
bright green for a highly desirable program, pate green 
lor a mildly desirable program, yellow lor a program thai 
is not likely to be relatively desirable or relatively unde- 
sirable, pale red for a mildly undesirable program, and 
bright red for a highly undesirable program. Any other 
suitable color gradations may be used, tn the alterna- 
tive, channel programming 102 for desirable programs 



might have clear backgrounds lor the textual informa- 
tion, channel programming 102 for programs that are 
neither desirable nor undesirable might have gray back- 
grounds, and programming information 102 for undasii- 

s able programs might be entirety blacked out over appro- 
priate time slots 114. Although the present invention 
contemplates scoring indicator s 1 1 6 in any suitable tor- 
mat, in one embodiment the use of coloring provides im- 
portant technical advantages, as discussed more fully 

to below. 

In operation of suggest module 76. control module 
72 communicates the viewer identity lor the viewer and 
program listing inlormation 6 for some or aD available 
• programs to suggest module 76. In response, suggest 

'S module 76 accesses the corresponding viewer profile 
84 in profile database B0. For each program, suggest 
module 76 uses scoring algorithm 77 to generate a pro- 
gram score indicating tho desirability of the program to 
tho viewer based on viewer profile 64 and program Sst- 

20 "ng information 6. For example, assume program listing 
information 6 for a particular program indicaled to scor- 
ing algorithm 77 that the program genre was comedy, 
that the program featured actor BiD Cosby, that a key- 
word associated with the program was fascinating,' 

25 and that the program was a ctosed-captioned rerun 
starting at 10:00p.m. and ending at 10:30p.m. on the 
current date on the fourth channel Rankhg 86 for 'com- 
edy' genre option 86 in viewer profile 84 might be a nu- 
meric value, such as *10" or other suitable value, indi- 

30 eating that the viewer strongly prefers comedy pro- 
grams. Similarly, ranking 68 lor "Bill Cosby* actor option 
B6 might be a '3" or other value indicating that the viewer 
mildly prefers Bill Cosby programs, and ranking BS for 
fascinating' keyword option 86 might be a '0' or other 

3S value indicating that the viewer is neutral regarding pro- 
grams with which fascinating' keyword option 86 might 
be associated. 

Still referring to the same example, scoring algo- 
rithm 77 might add, average, or otherwise manipulate 

40 rankings 88 for the program to determine a score for the 
program 1o indicate the degree to which the viewer is 
likely to enjoy the program, considering all applicable 
information within program" feting information 6 and 
viewer profile 84. which is fikety to be relatively high lor 

45 this example. In one embodiment, scoring module 77 
determines a score for every program for which pre- 
ferred schedule 100 contains channel programming 
102. For programs having scores in a highest percentile 
range, such as in the highest fifteen percent of scores 

so or any other specified range, suggest module 76 may 
associate the appropriate colored scoring indicator 118. 
such as green, cjsar, or other suitable scoring indicator 
116, with the program within prel erred schedule 100 to 
overlay textual information concerning the program. For 

" programs with scores in a middle percentile range, sug- 
gest module 76 may associate a yellow, gray, or other 
scoring indicator 116 wilh the program. For programs 
having scores in a lowest percentile range, suggest 
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module may associate red with the program, black out 
tho program and associated textual information Irom 
preferred schedule 100, or provide scoring indicator 116 
to the viewer in any other manner to indicate relative 
undesirability ol the programs. 

According to the particular scoring algorithm 77, the 
particular scheme tor scoring indicators 116, program 
listing inlormation 6, end viewer profile 64, the viewer is 
able to consult preferred schedule 100 to intelligently 
solect Irom among myriad available viewing opportuni- 
ties. Since preferred schedule 100 is color coded ac- 
cording to the degree to which programs are likely to be 
enjoyable, the viewer need not have any understanding 
or knowledge of scoring algorithm 77. the scores deter- 
mined for any program or the relationship between the 
scores determined lor any collection ol programs, or any 
other aspect ol the manner in which suggest module 7S 
generates preferred schodulo 100. The viewer may 
specily any suitable correspondence between percen- 
tile ranges lor program scores and the colors used lor 
scoring indicators 116 lo customize EPG 70 in accord- 
ance with particular needs. Scoring algorithm 77 may 
be replaced or modified without altering the functionality 
of EPG 70 Irom the perspective of the viewer, because 
the mapping between the desirability of a program and 
scoring indicator 116 is consistent, such that the viewer 
always receives channel programming 102 in a formal 
tho viewer can readily understand and appreciate. 

Referring again to FIGURE 5, in time slot 114 be- 
tween 10:00p.m. and 10:30p.m., channel programming 
104 lor the second channel, channel programming 109 
lor the fourth channel, and channel programming 112 
(or the sixth channel all have clear scoring Indicators 
116. which would overlay textual inlormation for corre- 
sponding programs, indicating thai tho programs on all 
three of these channels are likely to be enjoyable to the 
viewer. In contrast, the first, third, and fifth channels 
have channel programming 102, 106, and 110. respec- 
tively, having gray or black scoring indicators 1 1 6, as the 
case may be. which Indicates that programs on these 
channels during this time slot 114 are not likely to be 
enjoyable to the particular viewer. As a result, if tho view- 
er consults preferred schedule 100 with respect to this 
time slot 114, the viewer can readily make a delermtna- 
tion regarding the channels to select, providing an im- 
portant technical advantage. In addition, preferred 
schedule 100 allows the viewer to make more intelligent 
decisions concerning which time slots 114 are likely to 
be most suitable for enjoyable viewing in accordance 
with the arrangement ol scoring Indicators 116. For ex- 
ample, if the concentration ol clear scoring indicators 
116 lor desirable programs is relatively high in one or 
more time slots 11 4, the viewer may plan viewing times 
for the viewer or other viewers within the household ac- 
cordingly. 

In one embodiment, EPG 70 allows the viewer to 
point to. click on. or otherwise select channel program- 
ming 102 for a particular program to hyperlink or estab- 



lish any suitable connection to a display that provides 
additional factual, descriptive, or other information relat- 
ing to the program, the associated program listing infor- 
mation 6. the score that scoring algorithm 77 generated 
s for the program, the percentile rank or range for the pro- 
gram associated with the program score, or any other 
suitable inlormation, in any combination, EPG 70 may 
allow the viewer to further hyperlink from this display to 
other displays providing further information concerning 
•o selected program listing information B. For example if 
the first display (or Ihe program includes a list ol actors 
appearing in the program, the viewer may point to, click 
on. or otherwise select the name of an actor to hyperlink 
or establish a connection to a second display providing 
is biographical information tor Ihe actor, other programs in 
which the actor appears, or any other suitable informa- 
tion concerning the actor. EPG 70 may allow the viewer 
to point to, click on, or otherwise select a particular time 
slot 114 to receive (he program score and other infor- 
iO mation lor some or all programs airing within al least a 
portion ol time stol 114, in descending order from high- 
est to lowest score or any other suitable order. The 
present invention contemplates any technique lor pro- 
viding the viewer with access to program-related infor- 
ms mation to allow the viewer to select program viewing and 
recording opportunities more Intelligently to enhance 
the tolevision-rclated experience. The viewer may pro- 
vide an appropriate URL al any lime to access the in- 
formation discussed above from Internet inlormation 
30 sources, such as a web page associated with an actor 
or program. 

Furthermore, EPG 70 allows the viewer to change 
from one channel, whether or not the channel is current- 
ly airing a relatively desirable program, to another chan - 
3S no) that is currently airing a relatively desirable program 
at any time during a viewing session. In one embodi- 
ment, the viewer presses the "channel up" button or oth- 
erwise provides an indication using input device 42 that 
' the viewer wishes to change channels. In response. 
40 EPG 70 changes to another channel, for example, the 
channel airing the program having the highest score rel- 
ative to the other programs currently airing on other 
channels, while bypassing channels that are not cur- 
rently airing a program satisfying the preferences ol the 
4S viewer currently in effect Since the viewer can modify 
the corresponding viewer profile 84 at any time or can 
select a particular program at any lime according to pref- 
erences the viewer may provide at any time, the viewer 
need not consult any printed programming guides to 
so make a viewing decision, which is an important technical 
advantage of ihe present invention. 

For examplOT referring aga'm to prelerred schedule 
100 in FIGURE 5, if the viewer is currently viewing a 
program on the first channel during time slot 114 be- 
55 tween 1 0:00p.m. and 1 0: 30p.m. and presses the "chan- 
nel up* button on input device 42, EPG 70 would cause 
receiver to to tune to the sixth channel currently airing a 
program that is likely to be desirable, as indicated by the 
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clear scoring indicator U 5 associated with channel pro- 
gramming 11 2 lor the sixth channel during time slot 1 1 4. 
SimBarty, if the viewer again presses the 'channel up' 
button, EPG 70 would cause receiver 10 to tune to the 
fourth channel, which is also airing a program having a 
clear scoring indicator 116. In this manner, the viewer is 
able to bypass the program airing on the tilth channel, 
which is not as likely to be enjoyable to the viewer, as 
indicated by the gray scoring indicator 1 1 6 associated 
with channel programming 1 10 (or the fifth channel. 

EPG 70 may also use additional criteria specified 
by the viewer or otherwise in determining which channel 
to tune to h response to an indication from the viewer 
that a channel change is desired. For example, if more 
than one channel is airing a program with a clear scoring 
indicator 116 during time slot 114, EPG 70 may cause 
receiver 10 to tune to the channel airing the program 
that started most recently. In this case, tor the 10:00p. 
m. to 10:30p,m, time slot 114, the fourth channel would 
be tuned to fust, the sixth channel second, and the sec- 
ond channel third, EPG 70 may use other information to 
determine which channel to select, lor example, the 
channel airing the program with the highest score, the 
channel airing a program that is not a rerun, or any other 
information. The present invention contemplates any 
suitable technique for selecting one or more alternative 
channels for viewing at any time during a viewing ses- 
sion. 

Since EPG 70 performs a channel selection proc- 
ess that is program-based rather than channel -based, 
the selection process dynamically adapts as programs 
aired on the various channels change. For example, 
during time slot 1 1 4 between 1 0: 30p.m. and 1 1 :00p.m. , 
EPG 70 might still preferentially tune receiver 10 to the 
fourth channel, but would not tune to the sixth channel 
for which channel programming 112 now includes a 
black scoring indicator 116 corresponding to a low like- 
lihood that the viewer will enjoy the program. EPG 70 
may preferentially select channels for viewing during 
lime slot 1 1 4 according to any appropriate combination 
of program listing information 6 retrieved from database 
48 using EPG API 60, link 1 4. and database server 46. 

EPG 70 also allows a viewer to control viewing hab- 
its and opportunities for other viewers, such as children 
in a household, due to the program-based naiure of 
EPG 70 and the functionality that EPG 70 provides. In 
one embodiment, the parent may fitter, block, or other- 
wise prevent a child from viewing a particular program 
or type of program thai has associated program listing 
information 6 satisfying a predetermined criterion or set 
of criteria. For example, if the parent wanted to prevent 
the child from viewing any program of the 'horror' genre, 
the parent could enter the corresponding preference in- 
formation using profile module 74 or otherwise, and the 
child might be required to provide identity information to 
EPG 70 to access television 40 when the parent was 
not present. If the child accessed system 2 while HOME 
BOX OFFICE was airing Halloween. EPG 70 would not 



allow the child to tune to the channel corresponding to 
HOME BOX OFFICE at that time, but would taier permi; 
the chDd to tune to the same channel while HOME BOX 
OFFICE was airing The Sound of Music or other reta- 

s lively preferable programming. The parent could also 
limit the total daily viewing of the child with respect to 
programs with program listing tnlormation 6 satisfying 
selected characteristics entered using profile module 74 
or otherwise. For example, the parent might use EPG 

w 70 to limri the daily viewing ol programs ol the 'cartoon* 
genre to two hours, alter which EPG 70 would not allow 
the child to select a channel that was currently airing a 
program o( that genre. The program-based nature of 
EPG 70 provides an important technical advantage over 

»s previous systems for providing programmrig informa- 
tion. 

Another important technical advantage of the 
present invention involves the ability to record programs 
using recorder 20 in accordance with viewer profiles 64. 

?o program listing information 6, or both viewer profiles 84 
and program listing information 6, without relying on the 
viewer to provide information concerning air dates, stan 
times, stop times, or channels for the programs, referred 
to collectively as broadcast information. Since EPG 70 

2S has access to the resources ol database 4B and pro- 
gram listing tnlormation 6, if the viewer provides EPG 
70 with the title or another suitable identifier lor a pro- 
gram, EPG 70 can use EPG API 60 and other compo- 
nents of platform 12 and receiver 10 to cause recorder 

30 20 to record Ihe program regardless of the date, time, 
or channel on which the program will air. For example, 
if the viewer specifies recording of aD episodes of 
M*A*S*H or another series. EPG 70 will cause M'A*S*H 
to be recorded even if the channel airing M"A*S*H 

as changes, the time at which M*A*S*H is aired changes, 
or the length of the M*A*S*H program changes because 
the program is a season premiere or lor any other rea- 
son, because EPG 70 continues to maintain access to 
the appropriate program listing information 6 in data- 

40 base 48. Eliminating the need lor tho viower to provide 
broadcast information is an important technical advan- 
tage. 

Srnilarty, the viewer can cause recorder 20 to 
record all programs associated with particular keyword 

45 or other options 86, such as 'James Bond" or another 
suitable keyword option 86. specify that reruns ol a pro- 
gram that is otherwise to be recorded are noi to be re- 
corded, or specify the recording of programs in any other 
suitable manner ushg EPG 70. Scoring algorithm 77 of 

50 suggest module 76 may also determine scores for each 
program available to be recorded according to program 
listing information 6 and an appropriate profile 64 stored 
in profile database BO. If the score lor a particular pro- 
gram exceeds a predetermined threshold specified by 

5S the viewer or otherwise, EPG 70 may cause the program 
to be recorded even though the viewer had no knowl- 
edge (hat Ihe program would be airing or even that the 
program existed. EPG 70 may record programs using 
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one or more recorders 20. For example, rf recorders 20 
are VCRa and EPG 70 supports multiple viewer profiles 
B4. EPG 70 may cause a program thai is relatively de- 
sirable lor a particular viewer according to associated 
viewer profile 64 to be recorded using recorder 20 cor- 
responding to the particular viewer. The recording of 
programs may be periodically modified by inactivating 
or removing selected viBwer profiles 84 from database 
80 in accordance with particular needs. 

Schedule module 78 of EPG 70 provides a conven- 
tional programming schedule in accordance with pro- 
gram listing information 6, bul does not include informa- 
tion concerning viewer preferences or other information 
associated wilh or determined according to viewer pro- 
files 84. Forexamplo, a viewer may point lo, click on. or 
select schedule module 78 using a menu display asso- 
ciated with EPG 70 or in any other suitable manner. In 
response, EPG 70 may display channel information 102 
for various channels over one or more time slots 114. 
as shown in FIGURE 5 and discussed above with refer- 
ence to preferred schedule 100, except that scoring in- 
dicators 116 are absent from the programming sched- 
ule. The present invention contemplates combining the 
programming schedule associated with schedule mod- 
ulo 78 and preferred schedule 100 associaled with sug- 
gost module 76 in any appropriate manner. Although 
EPG 70 is discussed with respect lo platform 12, the 
present mention contemplates EPG 70 running on any 
platform suitable to support JAVA-basad operation o( 
EPG 70. The present invention further contemplates 
one or more modules of EPG 70 being integral to one 
or more other modules or distributed lo operate on 
processing platforms exiemal to platform 12. 

FIGURE 6 is a flow chart illustrating an exemplary 
method for solocting a program lot viowing according to 
Ihe operation of EPG 70. The method begins at step 
200, where Ihe viewer provides viewer preference infor- 
mation lo EPG 70 using one or mors preference tem- 
plates 82 and input device 42 or in any other manner. 
At step 202, profile module 74 receives the viewer pref- 
erence information, either directly or through control 
module 72, in the form of rankings 88 corresponding to 
preference options 86. As discussed more fully above, 
options B6 may include genre options 66, aclor options 
86, sports team options 86, keyword options 86. or any 
other suitable options 86. Profile module 74 generates 
viewer profile 84 for the viewer at step 204 and. at stop 
206. stores viewer profile 84 in profile database 80. In 
one embocfiment, viewer profile B4 includes rankings 83 
for each preference option B6 to provide an indication 
of the retative desirability to the viewer of programming 
that is associaled with the particular option 06. Suggest 
module 76. control module 72. or another suitable com- 
ponent of EPG 70 receives viewer input at step 207, 
whfch may include Ihe viewer turning on television 40, 
accessing EPG 70 in some manner, or otherwise indi- 
cating that Uio viowor wishos to view television program- 
ming. 



At step 20fi, suggest module 76 accesses viewer 
profile B4 in profile database 80 and program listing in- 
formation 6 in program listing database 43, in coopera- 
tion with EPG API 60, link 14. and database server 46. 
s Suggest module 76 may access one or more local da- 
tabases periodically updated to contain program listing 
information 6 to replace or combine with accessing da- 
tabase 43. Suggest module 76 may access program list- 
ing information 6 for all programs airing on a particular 
10 date, within one or more time slots 11 4, or any other set 
of programs. At step 21 0, suggest module 76 and asso- 
ciated scoring algorithm 77 calculate, determine, or oth- 
erwise generate a program score (or each program ac- 
cording to viewer profile 64 and program listing informa- 
fS tion 6. At step 21 2, suggest module 76 generates pre- 
ferred schedule 100 having channel programming 102 
for appropriate time slots 114. In one embodiment, a 
scoring indicator 116 is associated with each program 
for which preferred schedule contains channel program- 
20 ming 1 02, in the form of a color overlaying textual infor- 
mation concerning the program or in any other format. 

Suggest module 76 may receive an indication at 
step 214 that a program change is appropriate. For ex- 
ample, the indication may include the viewer pressing a 
zs 'channel up" button on input device 42 or providing any 
other suilablo indication. Alternatively, if the viewer is a 
child, thB parent may have instructed EPG 70 to prevent 
the child tram viewing programming of a particular gen- 
re. The indication may include the child selecting a chan- 
30 nel currently airing a program having the undesirable 
genre or the ending of a desirable program airing on a 
channel that subsequently begins to air a program hav- 
ing the undesirable genre. II the indication is received 
at step 214, suggest module 76 selects a program at 
35 step 216 that is more likely to be desirable, according to 
program scores tor the other programs lor which pre- 
ferred schedule 100 contains channel programming 
102^ and the method ends. If the indication is not re- 
ceived at etep 21 4, viewing continues as before and the 
40 method ends. Steps 200 through 216 may be repealed 
as many times and in any relative order as appropriate 
to allow viewers to modily viewer profiles 64, to select 
an alternative program for viewing during a viewing ses- 
sion, orto otherwise implement any of the functionalities 
45 that EPG 70 supports. 

FIGURE 7 is a flow chart illustrating an exemplary 
method for recording a television program according to 
the operation of EPG 70. The method begins at step 
300, where the viewer provides viewer input information 
so to EPG 70. In one embodiment, the input information 
may include a program identifier lor the program to be 
recorded, such as a title for the program, any preference 
option 86 discussed above, or any combination of a pro- 
gram identifier and one or more preference options 66. 
ss Since EPG 70 is program-based, the input information 
need nol Include broadcast information, such as an air 
dato. start time, stop time, or channel. Since EPG 70 is 
able to cause recorder 20 to record any program using 
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a program identifier tor the program, without information 
tram the viewer regarding the air date, start time, slop 
time, or channel, preference information may not be 
necessary. In the alternative, the viewer may instruct 
EPG 70 lo cause recorder 20 to record all previously 
unidentified programs satisfying viewer profile £4, in 
which case input information would include at least 
some viewer preference information Suggest module 
76 receives the input information at step 302, directly or 
through control module 72 or any other suitable compo- 
nent of EPG 70. 

Suggest module 76 accesses program listing infor- 
mation 6 at step 304 stored locally or in database AS 
using EPG API 60. link 14. and database server 46. At 
step 306. suggest module 76 compares the input infor- 
mation, such as the program identifier or viewer profile 
84 generated using the preference information for the 
viewer, with program listing information 6 in database 
43. In accordance with the comparison performed at 
step 306, suggest module 76 generates recording infor- 
mation for the program at step 308. For example, if a 
program for which database 40 contains program listing 
information 6 satisfies a predetermined threshold score 
associated with viewer profile 84. then suggest module 
76 may generate the recording information for the pro- 
gram lo cause the program to be recorded. 

The recording information may include any instruc- 
tion or set of instructions suitable to cause recorder 20 
to record the program, such as an air date, start time, 
stop time, channel, or other information relating to the 
airing of the program. The present invention contem- 
plates thB recording information being an instruction to 
EPG API 60, control API 60. or another component of 
platform 1 2 to initiate recording of the program. At step 
310, suggest module 76. control module 72. or another 
component of EPG 70 communicates the recording in- 
formation lor the program to EPG API 60. control API 
60, or any other appropriate component of platform 1 2 
or system 2 to hstruct recorder 20 to record the pro- 
gram, and the method ends. The present invention con- 
templates the sleps illustrated in FIGURES 6 and 7 co- 
operating in any suitable manner to a Dow one or more 
viewers to more intelligently select, schedule, and 
record viewing opportunities according to operation ol 
EPG 70 and system 2. 

Although the present invention has been descrbed 
with several embodiments, a plethora ol changes, sub- 
stitutions, variations, alterations, transformations, and 
modifications may be suggested to one skilled in the an, 
and it is intended that the present invention encompass 
such changes, substitutions, variations, adorations, 
transformations, and modifications as fall within the spir- 
it and scope ol the teachings disclosed herein. 



Claims 

1. An electronic programming guide lor compuling 



platform associated with a television, the platform 
operable to access a program listing database con- 
taining program listing information for a plurality of 
television programs, the electronic programming 
* guide comprising; 

a profile database for storing a viewer profile- 
and 

. a suggest module coupled to the profile data- 
»t> base lor accessing the viewer profile and the 

program listing information and, in response, to 
generate a preferred schedule according to Ihe 
viewer profile and Ihe program listing informa- 
tion, the preferred schedule indicative of th e de- 
ts sirabPity of a particular program relative lo other 

programs. 

2. The electronic programming guide of Claim 1, fur- 
ther comprising a profile module tor receiving view- 

SO er preference information and, in response, for gen- 
erating the viewer profile. 

3. The electronic programming guide ol Clam 2, 
wherein the profile module is operable to provide a 

25 preference template to the viewer for receiving the 
viewer preference information. 

4. The electronic programming guidB ol any preceding 
Claim, wherein the viewer profile includes a ranking 

so corresponding loan option selected from the group 
consisting of: 

a genre opl ion; 
an actor option; 
& a sports team option; and 

a keyword option. 

5. The electronic programming guide of any preceding 
Claim, wherein the suggest module comprises a 

« seeding algorithm for generating a score for the pro- 
gram according to the viewer profile and the pro- 
gram lisling information. 

6. The electronic programming guide of Claim 5, 
•*5 wherein the suggest module is further operable to 

associate a color with the program in (he preferred 
schedule according to the score for the program. 

7. The electronic programming guide of Claim 5 or 
50 Claim 6, wherein the suggest module is further op- 
erable to select a channel for viewing according to 
the score for. the program. 

8. The electronic programming guide of any preceding 
ss Claim, wherein the viewer profile comprises an op- 
tion that corresponds to an undesirable program, 
the suggest modulo operable to prevent viewing of 
the undesirable program in accordance with the op- 
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lion and program listing information tor the undesir- 
able program. 

9. A method performed on a computing platform that 
is associated with a television tor providing function- 
ality associated with an electronic programming 
guido, the method comprising: 

storing a viewer profile in a profile database; 
accessing the viewer profile in the profile data- 10 
base and program listing information stored in 
a program listing database for a plurality of tel- 
evision programs; and 

generating a preferred schedule in accordance 
with Ihe viewer profile and the program listing '* 
information, the preferred schedule indicative 
of the desirability of a particular program rela- 
tive to other programs. 

10. The method o( Claim 9, further comprising lha steps 20 



of the undesirable program according to the option 
and program fisting information for the undesirable 
program. 

17. A method performod on a computing platform that 
is associated with a television and a recorder for re- 
cording a television program, the method compris- 



recerving viewer preference information; and 
generating the viewer profile according to the 
viewer preference information. 

11. The method of Claim 10, further comprising the step 
of providing a preference template to the viewer for 
receiving the viewer preference information. 

12. The method of any of Claims 9 to 11, wherein the 
step of storing the viower profile comprises storing 
a viewer profile having a ranking corresponding to 
an option selected from the group consisting of: 

a genre option; 
an actor option; 
a sports team option; and 
a keyword option. 

40 

13. The method of any of Claims 9 to 12, further com- 
prising Ihe step of generating a score for the pro- 
gram according to the viewer profile and the pro- 
gram listing information. 

45 

14. Themethodof Claim 13, further comprising the step 
of associating a color with the program in the pre- 
ferred schedule according to the score lor the pro- 
gram. 

so 

15. The method ol Claim 13 or Claim 14, further com- 
prising the step of selecting a channel for viewing 
according to the score lor the program. 

16. The method of any of Claims 9 to IS, wherein the « 
step o( storing Ihe viower profile having storing a 
viewer profile comprises an option that corresponds 

to an undesirable program, and preventing viewing 



receiving viewer input information; 
accessing program listing information for a plu- 
rality of programs stored in a program listing da- 
tabase coupled to the platform; 
comparing the input information with the pro- 
gram listing information; 
generating recording information for the pro- 
gram In accordance with the comparison: and 
communicating recording information for the 
program lo Ihe recorder lo instruct the recorder 
lo record Ihe program. 

18. The method of Claim 1 7, wherein the step ol receiv- 
ing viewer input information comprises receiving 
viewer input information comprising a program titte. 

19. The method of Claim 17, wherein the step of receiv- 
ing viewer input information comprising receiving 
viewer input information comprises viewer prefer- 
ence information that includes a ranking corre- 
sponding to an option selected from the group con- 
sisting of; 

a genre option; 
an actor option: 
a sports team option; and 
a keyword option. 

20. The method of Claim 1 9, further comprising the step 
of generating a score lor the program according to 
the viewer preference information and the program 
listing information. 
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Electronic television program guide system and method 



(57) An electronic programming guide (70) operates 
on a computing platform (1 2) associated with a televi- 
sion (40). Tho platlarm (12) accesses a program listing 
database (48) containing program listing information (5) 
for a plurality of television programs. The electronic pro- 
gramming guide (70) includes a profile database (B0) 
thai stores a viewer profile (84) and a suggest module 
(76) that is coupled to the profile database (60). The sug- 
gest module (76) accesses the viewer profile (84) and 



tho program listing information (6) and. in response, 
generates a preferred schedule (100) according lo the 
viewer profile (84) and 1he program listing information 
(6). The preferred schedule (100) indicates the desira- 
bility of a particular program relative to other programs. 
Tho electronic programming guide (70) may also be 
used to Instruct a recorder (20) to record a television 
program in accordance with the program listing informa- 
tion (6) and viewer input information that does not spec- 
ify broadcast information concerning the program. 
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